// pages/shoplist/shoplist.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    // 页面查询参数
    query: null,
    // 店铺列表
    shopList: [], // 店铺列表数据
    // 列表查询参数
    page: 1, // 页码
    pageSize: 10, // 每页数据大小
    isLoading: false, // 页面是否在请求数据
    total: 0, // 当前查询条件的列表总数
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    console.log(options)
    // 把页面的查询参数赋值到页面状态中
    this.setData({
      query: options
    })

    // 获取店铺列表数据
    this.getShopList()
  },

  // 获取店铺列表数据
  getShopList(stopPullDownCb){
    // 请求发起前展示loading提示框
    wx.showLoading({
      title: '数据加载中...',
    })
    // 页面加载数据状态
    this.setData({
      isLoading: true
    })

    // 发起请求
    wx.request({
      url: `https://applet-base-api-t.itheima.net/categories/${this.data.query.id}/shops`,
      method: 'GET',
      data: {
        _page: this.data.page,
        _limit: this.data.pageSize
      },
      success: (res) => {
        console.log('shoplist',res)
        // 设置数据到页面上
        this.setData({
          shopList: [...this.data.shopList, ...res.data],
          total: parseInt(res.header['X-Total-Count'])
        })
      },
      complete: () => {
        // 请求完毕后隐藏loading提示框
        wx.hideLoading()
        // 页面加载数据状态
        this.setData({
          isLoading: false
        })
        // 判断回调是否存在，存在即调用
        stopPullDownCb && stopPullDownCb()
      }
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {
    // 设置页面的title
    wx.setNavigationBarTitle({
      title: this.data.query.title,
    })
  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {
  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    // 重置关键数据
    this.setData({
      page: 1,
      pageSize: 10,
      shopList: [],
      isLoading: false,
      total: 0
    })
    this.getShopList(() => {
      wx.stopPullDownRefresh()
    })
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    // 保证上次请求的数据已经返回
    if(this.data.isLoading) return

    // 检查当前查询数据已经是否全部加载完毕
    if(this.data.shopList.length === this.data.total) return wx.showToast({
      title: '数据已经加载完毕',
      icon: 'none'
    })

    // 触底加载下一页数据
    this.setData({
      page: this.data.page + 1
    })
    // 获取店铺列表
    this.getShopList()
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})